<!DOCTYPE html>
<title>Test MediaDevice navigator.mediaDevices.setCaptureHandleConfig()</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/utils.js"></script>
<script src="/common/dispatcher/dispatcher.js"></script>
<script src="resources/utils.js"></script>

<body>
<script>
promise_test(async () => {
  const frame = attachFencedFrameContext();
  await frame.execute(async () => {
    // If capture handle is set inside the fenced frame, it should fail because
    // it should not be the top-level browsing context.
    // https://w3c.github.io/mediacapture-handle/identity/index.html#set-capture-handle-config
    try {
      navigator.mediaDevices.setCaptureHandleConfig({
        handle: 'dummyhandle',
        permittedOrigins: ["*"],
      });
      throw 'The setCaptureHandleConfig request should not succeed.';
    } catch (e) {
      assert_equals(e.name, 'InvalidStateError');
      assert_equals(e.message,
        "Failed to execute 'setCaptureHandleConfig' on 'MediaDevices': " +
        'Can only be called from the top-level document.');
    }
  });
}, 'navigator.mediaDevices.setCaptureHandleConfig');
</script>
</body>
